package com.yss.reportworld.domain;

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.yss.common.core.annotation.EasyExcel;
import com.yss.common.core.utils.easyexecl.IntegerConverter;
import lombok.Data;
import lombok.EqualsAndHashCode;
import com.yss.common.core.web.domain.BaseEntity;

import javax.validation.constraints.NotBlank;
import java.util.List;

/**
 * 报表世界数据地图对象 report_world_data_map
 *
 * @author yss
 * @date 2023-05-25
 */
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("report_world_data_map")
public class DataMap extends BaseEntity {

    /**
     * 技术主键
     */
    @ExcelIgnore
    @TableId("ID")
    private String id;

    /**
     * 被依赖表名
     */
    @NotBlank(message = "被依赖表名不能为空")
    @TableField("TABLE_NAME_RELY")
    @ExcelProperty("被依赖表名")
    private String tableNameRely;

    /**
     * 表名
     */
    @NotBlank(message = "表名不能为空")
    @TableField("TABLE_NAME")
    @ExcelProperty("表名")
    private String tableName;

    /**
     * 依赖字段
     */
    @TableField("COLUMN_NAME_RELY")
    @ExcelProperty("依赖字段")
    private String columnNameRely;

    /**
     * 字段名称
     */
    @TableField("COLUMN_NAME")
    @ExcelProperty("字段名称")
    private String columnName;

    /**
     * 版本号
     */
    @ExcelIgnore
    @ExcelProperty(value = "版本号")
    @TableField("VERSION")
    private String version;

    /**
     * 文件名称
     */
    @ExcelProperty("来源")
    @TableField("FILE_NAME")
    private String fileName;

    /**
     * 状态
     */
    @ExcelProperty(value = "状态", converter = IntegerConverter.class)
    @EasyExcel(readConverterExp = "1=正常,2=停用")
    @TableField("STATUS")
    private Integer status;
    /**
     * 历史版本号
     */
    @ExcelIgnore
    @TableField(exist = false)
    private String hisVersion;

    @TableField(exist = false)
    @ExcelIgnore
    private List<String> idList;

    // 导出的时候选择 数据的主键
    @ExcelIgnore
    @TableField(exist = false)
    private String ids;
}
